

# Internal EMAC (APLL) clock, configurable PHY clock output





All committers have signed the CLA.

Member

Thanks for the PR! Would you mind changing the configuration to run-time instead of Kconfig? I.e. add the necessary options to eth\_config\_t and pass them where needed. This way, Ethernet driver can be used in environments where configuration is not known at compile time (such as micropython an Arduino).

This also means that there is going to be an extra overhead of rtc\_clk\_apl1\_enalbe being linked into the IRAM
of output binary even if internal clock is not used. This can be remedied by adding a "Support internal clock
generation using APLL" option in Ethernet Kconfig, and wrapping corresponding parts of code if #ifdef ,
returning ESP\_ERR\_NOT\_SUPPORTED if APLL is disabled in Kconfig but requested at run time.



 $\odot$ 



sauttefk commented on Oct 17, 2017

Contributor (Author

OK, changed. The Ethernet clock configuration is now part of the eth\_config\_t structure. But I'm not sure if it makes sense to exclude <code>soc/rtc.h</code> by an <code>#ifdef</code> this saves just 360 bytes. I also think, that using the internal clock will be the default usage in the future as this reduces the hassle with GPIOO, makes one crystal oscillator obsolete and potentially frees one GPIO pin.





sauttefk mentioned this pull request on Oct 18, 2017

ETH\_LAN8720 espressif/arduino-esp32#744



sauttefk commented on Oct 23, 2017

Contributor Author

please merge



sauttefk commented on Oct 30, 2017

Contributor Author

@igrr: please merge this PR, so we can easily procede here: https://github.com/espressif/arduino-esp32





R projectgus self-assigned this on Oct 30, 2017

projectgus commented on Oct 30, 2017

Contributor

I'm sorry for the delay, @sauttefk . This has been waiting on someone (nominally me) to wire up a PHY and run some tests with internal & external clock configs, but I keep getting pulled onto other tasks.

(If you can clarify which clock configs you also tested with the WaveShare board then this may help speed things along.)



sauttefk commented on Oct 31, 2017

Contributor

Author

<u>@projectgus</u> I took my waveshare test setup (here) removed the two  $33\Omega$  vertical resistors below the LAN8720 and mounted one of the  $33\Omega$  resistors horizontally between the upper two pads. In this way, the crystal oscillator is completely disconnected and I can choose between GPIO0, GPIO16 or GPIO17 as clock source. GPI017 (the inverted signal EMAC\_CLK\_OUT\_180) works perfect. GPI00 and GPI016 also worked, but not very stable (only when some additional capacitive load was on the clock signal - i.e. the probe of my oscilloscope or after i added a 74hct04 inverter in between). I haven't analysed this any further, maybe this is because of the sampling time of the other data signals relative to the clocks edge or due to additional delay due to the inversion of the clock.

What I can tell: I was pinging the test board over 3 days without one ping missed with GPI017 as clock source.







igrr added the Status: Pending label on Nov 10, 2017



R igrr unassigned projectgus on Nov 10, 2017



sauttefk mentioned this pull request on Nov 14, 2017

[TW#16425] SD card file system & ethernet compatibility issue #1237



Set GPIO-mode for MDC and MDIO pins

51badec

sauttefk commented on Nov 14, 2017

Contributor Author

## Please merge this PR.

My prototype PCB using EMAC\_CLK\_OUT\_180 on GPI017 with LAN8720 and POE is working now several days without any issues...









## igrr commented on Nov 14, 2017

Member

Sorry for the slow turnaround @sauttefk, this PR had been cherry-picked in f324458. Note that the last commit you added wasn't included, as we grabbed the version of this PR about 4 days ago.





grr closed this on Nov 14, 2017



## [TW#24566] LAN8720 TX issue with ethernet\_example (IDFGH-1393) #2164



#### cnlohr commented on Jul 10, 2018

Contributor

Just confirming, @sauttefk you had to include an inverter when using GPIO16/GPIO0? Right now it looks like I'm getting 100% packet throughput going into the ESP32, but TXing from the ESP32, I'm at 0% sending. I am not even getting "errors" on the other end.



#### Matheus-Garbelini commented on Jul 16, 2018 • edited ▼

@cnlohr What inverter are you using?

I'm buying this NL17SZ00DFT2G IC which seems to operate up to 100Mhz. But we still need confirmation if this works correctly.



#### cnlohr commented on Jul 17, 2018

Contributor

It will likely introduce a phase delay, which could be troubling. What I really want to do is to try to phase-delay the GPIO0 output enough to get it to work with, saving GPIO 16/17.







Status: Pending label on Aug 9, 2018



Curclamas pushed a commit to Curclamas/arduino-esp32 that referenced this pull request on Aug 21, 2018



💴 Allow configuration of Ethernet PHY clock source (espressif#916) 📖

a1acc55

# HarterHorst commented on Sep 23, 2018 • edited ▼

@sauttefk i have the same setup like you have mentioned above. Removed the two 33 Ohm resistors and put one horizontally between the two pads below the 8720. I have connected PIN17 with pull up 3,3 volt to nINT/RETCLK and configured #define ETH\_CLK\_MODE ETH\_CLOCK\_GPIO17\_OUT in the Arduino script. Pin 0 is not connected.

Script starts and goes "ETH Started". Thats it, nothing more.

rst:0x1 (POWERON\_RESET),boot:0x13 (SPI\_FAST\_FLASH\_BOOT) configsip: 0, SPIWP:0xee clk\_drv:0x00,q\_drv:0x00,d\_drv:0x00,cs0\_drv:0x00,hd\_drv:0x00,wp\_drv:0x00 mode:DIO, clock div:1 load:0x3fff0018,len:4 load:0x3fff001c,len:1324 load:0x40078000,len:7788 ho 0 tail 12 room 4 load:0x40080400,len:6448 entry 0x400806e8 ESP32 SDK: v3.2-dev-1055-g3276a1316 ETH Started

Cabling goes via breadboad (i know that this will cause trouble with 50MHz) so I checked the signal. Unfortunatly my cheap Oscilloscope can only handle max 25MHz but what I see looks OK for me.

Did I miss something when I use the ESP Arduino framework and not the ESP-IDF? The OLIMEX ESP32-EVB works.



coyool mentioned this pull request on May 8, 2020

GPIO0 can not be used as CLK sorce for ETH together with PSRAM espressif/arduinoesp32#3979



Reviewers

No reviews

Assignees

No one assigned

Labels

None yet

**Projects** 

None yet

Milestone

No milestone

Development

Successfully merging this pull request may close these issues.

None yet

# 7 participants











